草庐IT

java - Hibernate NOT IN 联结表上的子查询

全部标签

ruby - mongoid查询缓存

Rails的ActiveRecord有一个称为查询缓存(ActiveRecord::QueryCache)的功能,它在请求的生命周期内保存SQL查询的结果。虽然我不太熟悉实现的内部结构,但我认为它将查询结果保存在Rackenv中的某个位置,该结果在请求结束时被丢弃。不幸的是,Mongoid当前不提供这样的功能,并且由于某些查询隐式发生(引用)这一事实而加剧了这种情况。我正在考虑实现此功能,而且我很好奇,应该在何处以及如何连接Mongoid(或者,也许是mongo驱动程序?)以实现此功能。 最佳答案 Mongoid有缓存,在http:

sql - 使用 SQL IN 和 SQL OR 运算符的 Rails 3 ActiveRecord 查询

我正在使用“where”语法编写一个Rails3ActiveRecord查询,它同时使用了SQLIN和SQLOR运算符,但不知道如何同时使用它们。此代码有效(在我的用户模型中):Question.where(:user_id=>self.friends.ids)#note:self.friends.idsreturnsanarrayofintegers但是这段代码Question.where(:user_id=>self.friends.idsOR:target=>self.friends.usernames)返回这个错误syntaxerror,unexpectedtCONSTANT,

ruby-on-rails - 如何修复 Rails 中 pg_attribute 表的缓慢隐式查询

在我们的生产环境中,我们注意到Rails应用程序频繁出现峰值(大约每1小时一次)。深入挖掘,这是由于以下查询在单个HTTP请求中累计运行时间超过1.5秒(称为100倍)。SELECTa.attname,format_type(a.atttypid,a.atttypmod),pg_get_expr(d.adbin,d.adrelid),a.attnotnull,a.atttypid,a.atttypmodFROMpg_attributeaLEFTJOINpg_attrdefdONa.attrelid=d.adrelidANDa.attnum=d.adnumWHEREa.attrelid=

ruby - session 越过。 Rails 上的 Ruby

我有一个使用devise进行身份验证的应用程序。ruby1.9.2上的Rails3,passenger位于nginx之上。这是我的问题:我注意到有时我的session会交叉。在以一个用户身份登录时,我有时会成为另一个用户。这真是一个可怕的问题。我已经设法通过使用active_recordsession存储让它停止。但我对它可能发生的地方感到困惑。它在使用cookie存储和memcached存储时都会发生。我不确定从哪里开始调试。我已经完成了我所有的代码,而且我只是从“current_user”中读取而不是写入。我没有任何代码在session中存储项目。任何人都可以给我建议,告诉我这可能

ruby-on-rails - ActiveRecord::Base 上的 alias_method 导致 NameError

我有一个直接从ActiveResource::Base继承的模型,我正在尝试为记录表中的大部分列运行alias_method,但结果是一个NameError:NameError:undefinedmethodaddress_line_1'forclassLeadImport::Base'但我可以访问属性:LeadImport::Base.new.address_line_1#=>nil(noterror)我的类(class)有一个名为address_line_1的表列,所以我没有看到问题。classLeadImport::Base规范:Ruby1.8.7、Rails2.3.8

ruby-on-rails - Rails:在具有警告的子文件夹中组织模型:B::A引用的顶级常量A

今天我决定重组大量与用户相关的模型,但遇到了问题。在我有这样的结构之前:app/models/user.rbapp/models/user_info.rbapp/models/user_file.rb...所以我将所有user_模型移动到user子文件夹中,如下所示:app/models/user.rbapp/models/user/info.rbapp/models/user/file.rb...并将它们的定义更改为classUser::InfoUser模型未更改(关联除外)。除User::File模型外,一切正常。当我尝试访问此模型时,出现以下错误:warning:toplevel

ruby-on-rails - 将模型上的所有方法调用委托(delegate)给关联

我有一个具有多态关联的ActiveRecord模型,如下所示:classReachtrueend这个模型就像一个代理。我需要做的是将对该对象的所有方法调用转发给关联的对象:reachable。我认为delegate在这里无济于事,因为我必须明确命名我需要委托(delegate)的所有方法。我需要像delegate:all这样的东西来委托(delegate)所有方法(不是all方法)。 最佳答案 从Rails5.1+开始,您可以委托(delegate)所有未使用delegate_missing_to:reachable实现的内容基本上

ruby - 自动记录 DataMapper 查询

我正在使用DataMapper在Sinatra中开发一个简单的应用程序。我想查看DM为我的各种链式查找器等创建的查询。我试过:DataMapper::Logger.new(STDOUT,:debug)在我的configuredo...endblock中,environment.rb文件会在应用程序启动时加载。我也试过:DataMapper::Logger.new('log/my-app.log',:debug)既不会从通过浏览器或通过需要我的应用程序的irbsession访问的应用程序生成日志语句。我确实看到了应用启动消息。我正在使用rackupconfig.ru在本地运行应用程序。我

ruby-on-rails - Heroku 上的 Rails 4.0.1,无法创建数据库

我无法让rakedb:migrate在Heroku上的Rails4.0.1应用程序上运行。我猜我没有正确配置postgres...但是阅读heroku上的文档并没有真正帮助,我不确定该怎么做。我不太了解heroku或postgres。任何帮助或资源将不胜感激。让我知道是否还有其他我可以发布的内容。(此外,如果重要的话,我正在使用设计)当我运行herokurunrakedb:migrate时,我得到了这个:Running`rakedb:migrate`attachedtoterminal...up,run.5077PG::UndefinedTable:ERROR:relation"use

ruby-on-rails - 将查询字符串附加到 url

我有一个回调url字符串params[:callback],我需要附加一个查询字符串"&result=true"并重定向用户。我发现这样做的更好方法是使用addressable但我认为代码对于这样的任务来说太大了,尤其是当我们谈论ruby​​时:callback=Addressable::URI.parse(params[:callback])query=callback.query_valuesquery[:result]='true'callback.query_values=queryredirect_tocallback.to_s是否有更优雅的方式来获得与此代码段相同的结果?